"""
数据库连接配置
"""
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker, Session
from typing import Generator
from utils.config import config

# 创建数据库引擎
engine = create_engine(
    config.SQLALCHEMY_DATABASE_URL,
    echo=True,  # 开发环境打印SQL语句
    pool_pre_ping=True,  # 连接池预检测
    pool_recycle=3600,  # 1小时回收连接
    pool_size=10,  # 连接池大小
    max_overflow=20,  # 最大溢出连接数
    pool_timeout=30,  # 获取连接的超时时间（秒）
    connect_args={
        "connect_timeout": 10,  # MySQL连接超时（秒）
        "read_timeout": 30,  # 读取超时（秒）
        "write_timeout": 30,  # 写入超时（秒）
    }
)

# 创建会话工厂
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)


def get_db() -> Generator[Session, None, None]:
    """
    获取数据库会话
    用于FastAPI依赖注入
    """
    db = SessionLocal()
    try:
        yield db
    finally:
        db.close()


